package arithmetic3.sort;

import java.util.Arrays;

/**
 * @author 姚凤桥
 * @Date 2021/12/14 11:15
 * @Description: 选择排序
 * 第一次从数组里面找出最小的数，放在第0个位置。第二次从除第0个位置后面的所有数里再找出最小的数，放在第1个位置.依次类推
 */
public class SelectSort {
    public static void main(String[] args) {
        int[] arr = {5, 4, 3, 2, 1};
        selectSort(arr);
        System.out.println(Arrays.toString(arr));
    }

    public static void selectSort(int[] arr) {
        for (int i = 0; i < arr.length - 1; i++) {
            int min = arr[i];
            int minIndex = i;
            for (int j = i; j < arr.length; j++) {
                if (arr[j] < min) {
                    min = arr[j];
                    minIndex = j;
                }
            }
            int temp = arr[i];
            arr[i] = arr[minIndex];
            arr[minIndex] = temp;
        }
    }
}
